// 引入全局样式
import './assets/main.less'

// Vue 相关库
import { createApp } from 'vue'
import { createPinia } from 'pinia'
import router from './router'
import App from './App.vue'

// 移动端适配
import './plugins/setRem' // 设置 rem 适配
import 'amfe-flexible' // 自动适配屏幕

// Element Plus 相关
import ElementPlus from 'element-plus'
import * as ElementPlusIconsVue from '@element-plus/icons-vue'
import zhCn from 'element-plus/dist/locale/zh-cn.mjs'
import 'element-plus/dist/index.css'

// Swiper 轮播图样式
import 'swiper/css'
import 'swiper/swiper-bundle.css'

// Pinia 相关
import piniaPluginPersist from 'pinia-plugin-persist'

// uno.css
import 'uno.css'

import isPhone from "@/utils/isPhone" // 自定义指令

// 创建 Pinia 实例并使用持久化插件
const Pinia = createPinia()
Pinia.use(piniaPluginPersist)

// 创建 Vue 应用实例
const app = createApp(App)

// 注册 Element Plus 组件和图标
for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
    app.component(key, component);
}

// 使用 Element Plus，并设置中文语言包
app.use(ElementPlus, {
    locale: zhCn,
})

// 挂载全局插件
app.use(Pinia)
app.use(router)

// 全局注册自定义指令
app.directive('isPhone', isPhone)

// 挂载 Vue 实例
app.mount('#app')
